<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Document</title>
    <style>
      .main {
        width: 800px;
        margin: 50px auto;
        padding: 20px;
      }
      * {
        box-sizing: border-box;
      }
      .flex-box {
        background-color: #f4f7f8;
        resize: horizontal;
        overflow: hidden;
        display: flex;
        margin: 1em;
        min-height: 100px;
      }

      .flex-item {
        margin: 1em;
        padding: 0.5em;
        width: 120px;
        min-height: 50px;
        min-width: 0;
        background-color: #1b5385;
        color: white;
        font-family: monospace;
        font-size: 13px;
      }

      .box {
        flex-flow: row nowrap;
      }

      .box1 {
        flex-flow: row-reverse nowrap;
      }

      .box2 {
        flex-flow: row nowrap;
      }

      .box3 {
        flex-flow: row nowrap;
        justify-content: space-between;
      }

      .box4 {
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: flex-start;
      }

      .box5 {
        flex-wrap: wrap;
        min-height: 200px;
        align-content: stretch;
      }
    </style>
  </head>
  <body>
    <div class="main">
      <h3>容器属性</h3>
      <!-- 容器属性：flex-direction | flex-wrap | flex-flow | justify-content | align-items | align-content -->

      <!-- flex-direction :属性决定主轴的方向（即项目的排列方向）row | row-reverse | column | column-reverse;
                row（默认值）：主轴为水平方向，起点在左端。
                row-reverse：主轴为水平方向，起点在右端。
                column：主轴为垂直方向，起点在上沿。
                column-reverse：主轴为垂直方向，起点在下沿。 -->

      <div class="flex-box box1">
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
      </div>

      <!-- flex-wrap:属性定义，如果一条轴线排不下，如何换行。nowrap | wrap | wrap-reverse;
      nowrap（默认）：不换行。
      wrap：换行，第一行在上方。
      wrap-reverse：换行，第一行在下方。 -->

      <div class="flex-box box2">
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
      </div>

      <!-- flex-flow: <flex-direction> || <flex-wrap>; -->
      <!-- flex-flow 属性是flex-direction属性和flex-wrap属性的简写形式，默认值为row nowrap。 -->

      <!-- justify-content 属性定义了项目在主轴上的对齐方式。 flex-start | flex-end | center | space-between | space-around; -->
      <!-- flex-start（默认值）：左对齐
      flex-end：右对齐
      center： 居中
      space-between：两端对齐，项目之间的间隔都相等。
      space-around：每个项目两侧的间隔相等。所以，项目之间的间隔比项目与边框的间隔大一倍。 -->

      <div class="flex-box box3">
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
      </div>

      <!-- align-items属性定义项目在交叉轴上如何对齐。flex-start | flex-end | center | baseline | stretch; -->
      <!-- flex-start：交叉轴的起点对齐。
           flex-end：交叉轴的终点对齐。
           center：交叉轴的中点对齐。
           baseline: 项目的第一行文字的基线对齐。
           stretch（默认值）：如果项目未设置高度或设为auto，将占满整个容器的高度。 -->

      <div class="flex-box box4">
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
      </div>

      <!-- align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线，该属性不起作用。flex-start | flex-end | center | space-between | space-around | stretch; -->
      <!-- flex-start：与交叉轴的起点对齐。
      flex-end：与交叉轴的终点对齐。
      center：与交叉轴的中点对齐。
      space-between：与交叉轴两端对齐，轴线之间的间隔平均分布。
      space-around：每根轴线两侧的间隔都相等。所以，轴线之间的间隔比轴线与边框的间隔大一倍。
      stretch（默认值）：轴线占满整个交叉轴。 -->
      <div class="flex-box box5">
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
      </div>

      <h3>项目的属性</h3>
      <!-- 项目的属性:order |  flex-grow | flex-shrink | flex-basis | flex  | align-self -->

      <!-- order 属性定义项目的排列顺序。数值越小，排列越靠前，默认为0。 order: <integer>; -->
      <div class="flex-box box">
        <div class="flex-item" style="order:2">2</div>
        <div class="flex-item" style="order:1">1</div>
        <div class="flex-item" style="order:3">3</div>
      </div>

      <!-- flex-grow 属性定义项目的放大比例，默认为0，即如果存在剩余空间，也不放大。 flex-grow: <number>; -->
      <div class="flex-box box">
        <div class="flex-item" style="flex-grow:2">2</div>
        <div class="flex-item" style="flex-grow:1">1</div>
        <div class="flex-item" style="flex-grow:1">1</div>
      </div>

      <!-- flex-shrink属性定义了项目的缩小比例，默认为1，即如果空间不足，该项目将缩小。 flex-shrink: <number>; /* default 1 */ -->
      <div class="flex-box box">
        <div class="flex-item" style="flex-shrink:0">0</div>
        <div class="flex-item" style="flex-shrink:1">1</div>
        <div class="flex-item" style="flex-shrink:1">1</div>
        <div class="flex-item" style="flex-shrink:2">2</div>
        <div class="flex-item" style="flex-shrink:1">1</div>
        <div class="flex-item" style="flex-shrink:1">1</div>
        <div class="flex-item" style="flex-shrink:2">2</div>
        <div class="flex-item" style="flex-shrink:1">1</div>
        <div class="flex-item" style="flex-shrink:1">1</div>
      </div>

      <!-- flex-basis属性定义了在分配多余空间之前，项目占据的主轴空间（main size）。浏览器根据这个属性，计算主轴是否有多余空间。它的默认值为auto，即项目的本来大小。
        flex-basis: <length> | auto; /* default auto */ -->
      <!-- 它可以设为跟width或height属性一样的值（比如350px），则项目将占据固定空间。  -->
      <div class="flex-box box">
        <div class="flex-item" style="flex-basis:200px;">200px</div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
        <div class="flex-item"></div>
      </div>

      <!-- flex属性是flex-grow, flex-shrink 和 flex-basis的简写，默认值为 0 1 auto。后两个属性可选。
        flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ] -->
      <div class="flex-box box">
        <div class="flex-item" style="flex:0 1 200px;">200px</div>
        <div class="flex-item" style="flex:1.5 1 200px;"></div>
        <div class="flex-item"></div>
      </div>

      <!-- align-self属性允许单个项目有与其他项目不一样的对齐方式，可覆盖align-items属性。默认值为auto，表示继承父元素的align-items属性，如果没有父元素，则等同于stretch。
        align-self: auto | flex-start | flex-end | center | baseline | stretch; -->

      <div
        class="flex-box box"
        style="align-items: flex-start;min-height:200px;"
      >
        <div class="flex-item"></div>
        <div class="flex-item" style=" align-self:stretch">stretch</div>
        <div class="flex-item" style=" align-self:center"></div>
        <div class="flex-item" style=" align-self:baseline"></div>
        <div class="flex-item" style=" align-self:flex-end"></div>
        <div class="flex-item"></div>
      </div>
    </div>
  </body>
</html>
